# CPSC-240 Computer Organization and Assembly Language

**Chapter 7** 

Instruction Set Overview

Instructor: Yitsen Ku, Ph.D.
Department of Computer Science,
California State University, Fullerton, USA





# **Outline**

- Notational Conventions
- Data Movement
- Addresses and Values
- Conversion Instructions
- Integer Arithmetic Instructions
- Logical Instructions
- Control Instructions
- Example Program, Sum of Squares



# **Notational Conventions**



#### **Notational Conventions**

- An instruction will consist of the instruction or operation itself (i.e., add, sub, mul, etc.) and the operands.
- The operands refer to where the data (to be operated on) is coming from and/or where the result is to be placed.



| Operand Notation                                                     | Description                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <reg></reg>                                                          | Register operand. The operand must be a register.                                                                                                                                                                                                |
| <reg8>, <reg16>,<br/><reg32>, <reg64></reg64></reg32></reg16></reg8> | Register operand with specific size requirement. For example, <b>reg8</b> means a byte sized register (e.g., <b>al</b> , <b>bl</b> , etc.) only and <b>reg32</b> means a double-word sized register (e.g., <b>eax</b> , <b>ebx</b> , etc.) only. |
| <dest></dest>                                                        | Destination operand. The operand may be a register or memory. Since it is a destination operand, the contents will be overwritten with the new result (based on the specific instruction).                                                       |
| <rxdest></rxdest>                                                    | Floating-point destination register operand. The operand must be a floating-point register. Since it is a destination operand, the contents will be overwritten with the new result (based on the specific instruction).                         |
| <src></src>                                                          | Source operand. Operand value is unchanged after the instruction.                                                                                                                                                                                |
| <imm></imm>                                                          | Immediate value. May be specified in decimal, hex, octal, or binary.                                                                                                                                                                             |
| <mem></mem>                                                          | Memory location. May be a variable name or an indirect reference (i.e., a memory address).                                                                                                                                                       |
| <pre><op> or <operand></operand></op></pre>                          | Operand, register or memory.                                                                                                                                                                                                                     |
| <op8>, <op16>,<br/><op32>, <op64></op64></op32></op16></op8>         | Operand, register or memory, with specific size requirement. For example, <b>op8</b> means a byte sized operand only and <b>reg32</b> means a double-word sized operand only.                                                                    |
| <label></label>                                                      | Program label.                                                                                                                                                                                                                                   |



# **Data Movement**



#### **Data Movement**

- The general form of the move instruction is: mov <dest>, <src>
- The source operand is copied from the source operand into the destination operand. Thevalue of the source operand is unchanged. The destination and source operand must beof the same size (both bytes, both words, etc.). The destination operand cannot be an immediate. Both operands cannot be memory.





# **Summary of Move Instructions**

| Instruction                    | Explanation                                                                                                                                                                                                                                                           |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| mov <dest>, <src></src></dest> | Copy source operand to the destination operand.  Note 1, both operands cannot be memory.  Note 2, destination operands cannot be an immediate.  Note 3, for double-word destination and source operand, the upper-order portion of the quadword register is set to 0. |
| Examples:                      | mov ax, 42 mov cl, byte [bvar] mov dword [dVar], eax mov qword [qVar], rdx                                                                                                                                                                                            |



# **Example**

Ex. Assuming the following data declarations:

```
dValue dd 0
bNum db 42
wNum dw 5000
dNum dd 73000
qNum dq 73000000
bAns db 0
wAns dw 0
dAns dd 0
qAns dq 0
```

To perform, the basic operations of:

```
dValue = 27
bAns = bNum
wAns = wNum
dAns = dNum
qAns = qNum
```



# **Example**

The following instructions could be used:

```
; dValue = 27
      dword [dValue], 27
mov
      al, byte [bNum]
mov
      byte [bAns], al
                                ; bAns = bNum
mov
      ax, word [wNum]
mov
      word [wAns], ax
                                ; wAns = wNum
mov
      eax, dword [dNum]
mov
      dword [dAns], eax
                                ; dAns = dNum
mov
      rax, qword [qNum]
mov
      qword [qAns], rax
                                ; qAns = qNum
mov
```



# **Addresses and Values**



#### **Addresses and Values**

 The only way to access memory is with the brackets ([]'s). Omitting the brackets will not access memory and instead obtain the address of the item. For example:

```
mov rax, qword [var1] ; value of var1 in rax
mov rax, var1 ; address of var1 in rax
```



#### **Addresses and Values**

 In addition, the address of a variable can be obtained with the load effective address, or lea, instruction.
 The load effective address instruction is summarized as follows:

| Instruction                      | Explanation                                             |  |  |  |  |  |  |  |  |
|----------------------------------|---------------------------------------------------------|--|--|--|--|--|--|--|--|
| lea <reg64>, <mem></mem></reg64> | Place address of <b><mem></mem></b> into <b>reg64</b> . |  |  |  |  |  |  |  |  |
| Examples:                        | lea rcx, byte [bvar]<br>lea rsi, dword [dVar]           |  |  |  |  |  |  |  |  |

 Additional information and extensive examples are presented in Chapter 8, Addressing Modes.



# **Conversion Instructions**



#### **Conversion Instructions**

- It is sometimes necessary to convert from one size to another size. For example, a byte might need to be converted to a double-word for some calculations in a formula.
- The process used for conversions depends on the size and type of the operand. The following sections summarize how conversions are performed.



# **Narrowing Conversions**

- Narrowing conversions are converting from a larger type to a smaller type (i.e., word to byte or doubleword to word).
- Ex1. if the value of 50 (0x32) is placed in the rax register, the al register may be accessed directly to obtain the value as follows:

mov rax, 50 mov byte [bVal], al



# **Narrowing Conversions**

• Ex2. if the value of 500 (0x1f4) is placed in the rax register, the al register can still be accessed.

mov rax, 500 mov byte [bVal], al

• In this example, the **bVal** variable will contain 0xf4 which may lead to incorrect results.



# **Widening Conversions**

- Widening conversions are from a smaller type to a larger type (e.g., byte to word or word to double-word).
- Since the size is being expanded, the upperorder bits must be set based on the sign of the original value.
- As such, the data type, signed or unsigned, must be known and the appropriate process or instructions must be used.



# **Unsigned Conversions**

- For unsigned widening conversions, the upper part of the memory location or register must be set to zero. Since an unsigned value can only be positive, the upper-order bits can only be zero.
- Ex3. to convert the byte value of 50 in the al register, to a quadword value in **rbx**, the following operations can be performed.

```
mov al, 50
mov rbx, 0
mov bl, al
```



# **Unsigned Conversions**

 An unsigned conversion from a smaller size to a larger size can also be performed with a special move instruction, as follows:

#### movzx <dest>, <src>

- Which will fill the upper-order bits with zero.
- The movzx instruction does not allow a quadword destination operand with a double-word source operand.
- As previously noted, a mov instruction with a double-word register destination operand with a double-word source operand will zero the upper-order double-word of the quadword destination register.



# **Summary of movzx Instruction**

| Instructio                                | n                                                                                                                                                                                                                       | Explanation                                                                                                                                                         |  |  |  |  |  |  |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| movzx<br>movzx<br>movzx<br>movzx<br>movzx | <pre><dest>, <src> <reg16>, <op8> <reg32>, <op8> <reg32>, <op16> <reg64>, <op8> <reg64>, <op8> <reg64>, <op16></op16></reg64></op8></reg64></op8></reg64></op16></reg32></op8></reg32></op8></reg16></src></dest></pre> | Unsigned widening conversion.  Note 1, both operands cannot be memory.  Note 2, destination operands cannot be an immediate.  Note 3, immediate values not allowed. |  |  |  |  |  |  |
|                                           | Examples:                                                                                                                                                                                                               | movzx cx, byte [bVar] movzx dx, al movzx ebx, word [wVar] movzx ebx, cx movzx rbx, cl movzx rbx, cx                                                                 |  |  |  |  |  |  |



# **Signed Conversions**

- For signed widening conversions, the upperorder bits must be set to either 0's or 1's depending on if the original value was positive or negative.
- Ex. given that the **ax** register is set to -7 (0xfff9), the bits would be set as follows:

| 15 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |



# **Signed Conversions**

• Since the value is negative, the upper-order bit (bit 15) is a 1. To convert the word value in the **ax** register into a double-word value in the **eax** register, the upper-order bit (1 in this example) is extended or copied into the entire upper-order word (bits 31-16) resulting in the following:

| 31 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |



# **Signed Conversions**

 A more generalized signed conversion from a smaller size to a larger size can also be performed with some special move instructions, as follows:

```
movsx <dest>, <src> movsxd <dest>, <src>
```

 The movsx instruction is the general form and the movsxd instruction is used to allow a quadword destination operand with a doubleword source operand.



# **Summary of Signed Widening Conversion**

| Instruction | Explanation                                                                                                             | Examples |
|-------------|-------------------------------------------------------------------------------------------------------------------------|----------|
| cbw         | Convert byte in <b>al</b> into word in <b>ax</b> .  Note, only works for <b>al</b> to <b>ax</b> register.               | cbw      |
| cwd         | Convert word in <b>ax</b> into double-word in <b>dx:ax</b> .  Note, only works for <b>ax</b> to <b>dx:ax</b> registers. | cwd      |
| cwde        | Convert word in <b>ax</b> into double-word in <b>eax</b> .  Note, only works for <b>ax</b> to <b>eax</b> register.      | cwde     |
| cdq         | Convert double-word in eax into quadword in edx:eax.  Note, only works for eax to edx:eax registers.                    | cdq      |
| cdqe        | Convert double-word in <b>eax</b> into quadword in <b>rax</b> .  Note, only works for <b>rax</b> register.              | cdqe     |
| cqo         | Convert quadword in rax into word in doublequadword in rdx:rax.  Note, only works for rax to rdx:rax registers.         | cqo      |



# **Summary of Signed Widening Conversion**

| Instruction                                        | n                                                                                                                                                                                                                                                        | Explanation                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| movsx<br>movsx<br>movsx<br>movsx<br>movsx<br>movsx | <pre><dest>, <src> <reg16>, <op8> <reg32>, <op8> <reg32>, <op16> <reg64>, <op8> <reg64>, <op16> <reg64>, <op16> <reg64>, <op16></op16></reg64></op16></reg64></op16></reg64></op8></reg64></op16></reg32></op8></reg32></op8></reg16></src></dest></pre> | Signed widening conversion (via sign extension).  Note 1, both operands cannot be memory.  Note 2, destination operands cannot be an immediate.  Note 3, immediate values not allowed.  Note 4, special instruction (movsxd) required for 32-bit to 64-bit signed extension. |  |  |  |  |  |
|                                                    | Examples:                                                                                                                                                                                                                                                | movsx cx, byte [bVar] movsx dx, al movsx ebx, word [wVar] movsx ebx, cx movsxd rbx, dword [dVar]                                                                                                                                                                             |  |  |  |  |  |



# **Integer Arithmetic Instructions**

Addition



#### **Addition**

 The general form of the integer addition instruction is as follows:

```
add <dest>, <src> ; <dest> = <dest> + <src>
```

- Specifically, the source and destination operands are added and the result is placed in the destination operand (over-writing the previous contents).
- The value of the source operand is unchanged.
- The destination and source operand must be of the same size (both bytes, both words, etc.).
- The destination operand cannot be an immediate.



#### **Addition**

```
Ex. assuming the following data declarations:
     bNum1 db
                42
            db
                73
     bNum2
     bAns
            db
                0
     wNum1 dw 4321
     wNum2 dw 1234
            dw
     wAns
                0
     dNum1 dd 42000
     dNum2 dd 73000
            dd
     dAns
     qNum1 dq
               42000000
               73000000
     qNum2
            dq
            dq
     qAns
To perform the basic operations of:
```

bAns = bNum1 + bNum2

qAns = qNum1 + qNum2

wAns = wNum1 + wNum2 dAns = dNum1 + dNum2



#### **Addition**

The following instructions could be used:

```
; bAns = bNum1 + bNum2
        al, byte [bNum1]
mov
        al, byte [bNum2]
add
        byte [bAns], al
mov
; wAns = wNum1 + wNum2
        ax, word [wNum1]
mov
        ax, word [wNum2]
add
        word [wAns], ax
mov
; dAns = dNum1 + dNum2
        eax, dword [dNum1]
mov
add
        eax, dword [dNum2]
        dword [dAns], eax
mov
; qAns = qNum1 + qNum2
        rax, qword [qNum1]
mov
        rax, qword [qNum2]
add
        qword [qAns], rax
mov
```



#### **Increment**

 In addition to the basic add instruction, there is an increment instruction that will add one to the specified operand. The general form of the increment instruction is as follows:

inc <operand> ; <operand> = <operand> + 1

 The result is exactly the same as using the add instruction (and adding one). When using a memory operand, the explicit type specification (e.g., byte, word, dword, qword) is required to clearly define the size.



#### **Increment**

 For example, assuming the following data declarations:

```
bNum db 42
wNum dw 4321
dNum dd 42000
qNum dq 42000000
```

To perform, the basic operations of:

```
rax = rax + 1
bNum = bNum + 1
wNum = wNum + 1
dNum = dNum + 1
qNum = qNum + 1
```



#### **Increment**

The following instructions could be used:



# **Summary of add and inc Instruction**

| Instruction                    | Explanation                                                                                                                                                                                                          |  |  |  |  |  |  |  |  |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| add <dest>, <src></src></dest> | Add two operands, ( <b>dest</b> > + <b>src</b> >) and place the result in <b>dest</b> > (over-writing previous value).  Note 1, both operands cannot be memory.  Note 2, destination operand cannot be an immediate. |  |  |  |  |  |  |  |  |
| Examples:                      | add cx, word [wVvar] add rax, 42 add dword [dVar], eax add qword [qVar], 300                                                                                                                                         |  |  |  |  |  |  |  |  |
| inc <operand></operand>        | Increment <b><operand></operand></b> by 1.  Note, <b><operand></operand></b> cannot be an immediate.                                                                                                                 |  |  |  |  |  |  |  |  |
| Examples:                      | inc word [wVvar] inc rax inc dword [dVar] inc qword [qVar]                                                                                                                                                           |  |  |  |  |  |  |  |  |

# **Addition with Carry**

- For assembly language programs the Least Significant
  Quadword (LSQ) is added with the add instruction and
  then immediately the Most Significant Quadword (MSQ)
  is added with the adc which will add the quadwords and
  include a carry from the previous addition operation.
- The general form of the integer add with carry instruction is as follows:

```
adc <dest>, <src> ; <dest> = <dest> + <src> + <carryBit>
```



# **Addition with Carry**

```
Ex. given the following declarations
```

```
dquad1 ddq 0x1A000000000000000
                                    ; 128 bits
dquad2 ddq 0x2C000000000000000
                                    ; 128 bits
                                    ; 128 bits
dqSum
        ddq 0
        rax, qword [dquad1]
mov
        rdx, qword [dquad1+8]
mov
add
        rax, qword [dquad2]
                                    ; add low 64 bits
adc
        rdx, qword [dquad2+8]
                                    ; add high 64 bits
        qword [dqSum], rax
mov
        qword [dqSum+8], rdx
mov
```



## **Summary of ADC Instruction**

| Instruction |                            | Explanation                                                                                                                                                                                                                                                                                                                             |                                           |
|-------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| adc         | <dest>, <src></src></dest> | Add two operands, ( <dest> + <src (over-writing="" (stored="" 1,="" 2,="" and="" be="" both="" cannot="" carry="" destination="" immediate.<="" in="" me="" note="" operand="" operands="" place="" previous="" register)="" result="" rflag="" th="" the="" value).=""><th>oit in the in <b><dest></dest></b> emory.</th></src></dest> | oit in the in <b><dest></dest></b> emory. |
|             | Examples:                  | adc rcx, qword [dVvar1]<br>adc rax, 42                                                                                                                                                                                                                                                                                                  |                                           |



# **Integer Arithmetic Instructions**

Subtraction



#### **Subtraction**

 The general form of the integer subtraction instruction is as follows:

```
sub <dest>, <src> ; <dest> = <dest> - <src>
```

- The source operand is subtracted from the destination operand and the result is placed in the destination operand (over-writing the previous value).
- The value of the source operand is unchanged.
- The destination and source operand must be of the same size (both bytes, both words, etc.).
- The destination operand cannot be an immediate.



#### **Subtraction**

Ex. Assuming the following data declarations:

```
bNum1
      db
           73
      db
           42
bNum2
bAns db
           0
wNum1 dw
          1234
wNum2 dw
         4321
wAns dw
dNum1 dd 73000
dNum2 dd 42000
   dd
dAns
qNum1 dq
          73000000
qNum2
      dq
           42000000
      dq
qAns
```

Question: To perform the basic operations of:

```
bAns = bNum1 - bNum2
wAns = wNum1 - wNum2
dAns = dNum1 - dNum2
qAns = qNum1 - qNum2
```



#### **Subtraction**

The following instructions could be used:

```
; bAns = bNum1 - bNum2
      al, byte [bNum1]
mov
sub al, byte [bNum2]
     byte [bAns], al
mov
; wAns = wNum1 - wNum2
      ax, word [wNum1]
mov
      ax, word [wNum2]
sub
     word [wAns], ax
mov
; dAns = dNum1 - dNum2
     eax, dword [dNum1]
mov
      eax, dword [dNum2]
sub
      dword [dAns], eax
mov
; qAns = qNum1 - qNum2
      rax, qword [qNum1]
mov
      rax, qword [qNum2]
sub
      qword [qAns], rax
mov
```



#### **Decrement**

 In addition to the basic sub instruction, there is an increment instruction that will subtract one from the specified operand. The general form of the decrement instruction is as follows:

dec <operand> ; <operand> = <operand> - 1

 The result is exactly the same as using the sub instruction (and subtracting one). When using a memory operand, the explicit type specification (e.g., byte, word, dword, qword) is required to clearly define the size.



#### **Decrement**

Ex. Assuming the following data declarations:

```
bNum db 42
wNum dw 4321
dNum dd 42000
qNum dq 42000000
```

Question: To perform, the basic operations of:

```
rax = rax - 1
bNum = bNum - 1
wNum = wNum - 1
dNum = dNum - 1
qNum = qNum - 1
```



#### **Decrement**

The following instructions could be used:



## Summary of sub and dec Instruction

| Instruction |                            | Explanation                                                                                                                                                                                                               |  |
|-------------|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| sub         | <dest>, <src></src></dest> | Subtract two operands, ( <b>dest</b> > - <b>src</b> >) and place the result in <b>dest</b> > (over-writing previous value).  Note 1, both operands cannot be memory.  Note 2, destination operand cannot be an immediate. |  |
|             | Examples:                  | <pre>sub cx, word [wVvar] sub rax, 42 sub dword [dVar], eax sub qword [qVar], 300</pre>                                                                                                                                   |  |
| dec         | <operand></operand>        | Decrement <b><operand></operand></b> by 1.  Note, <b><operand></operand></b> cannot be an immediate.                                                                                                                      |  |
|             | Examples:                  | dec word [wVvar] dec rax dec dword [dVar] dec qword [qVar]                                                                                                                                                                |  |



# **Integer Arithmetic Instructions**

Multiplication



## Multiplication

- Mul instruction is used for unsigned multiplication. Imul instruction is used for signed multiplication.
- Multiplication typically produces double sized results. That is, multiplying two *n*-bit values produces a 2*n*-bit result.



 The general form of the integer multiplication instruction is as follows:

- Where the source operand must be a register or memory location. An immediate operand is not allowed.
- For the single operand multiply instruction, the A register (al/ax/eax/rax) must be used for one of the operands.
- The other operand can be a memory location or register, but not an immediate.
- The result will be placed in the A and possibly D registers.





#### Quadwords

|     | rax  |
|-----|------|
| ×   | op64 |
| rdx | rax  |



Ex. assuming the following data declarations:

| bNum1 | db | 42          |
|-------|----|-------------|
| bNum2 | db | 73          |
| wAns  | db | 0           |
| wAns1 | dw | 0           |
| wNum1 | dw | <b>/1</b> 2 |

| wNum1 | dw | 4321 |
|-------|----|------|
| wNum2 | dw | 1234 |
| dAns2 | dw | 0    |

| dNum1 | dd | 42000 |
|-------|----|-------|
| dNum2 | dd | 73000 |
| qAns3 | dd | 0     |

| qNum1  | dq | 42000000 |
|--------|----|----------|
| qNum2  | dq | 73000000 |
| daAns4 | da | 0        |



```
Question: To perform the basic operations of:
     wAns = bNumA^2
                                     ; bNumA squared
      bAns1 = bNumA * bNumB
     wAns1 = bNumA * bNumB
     wAns2 = wNumA * wNumB
     dAns2 = wNumA * wNumB
     dAns3 = dNumA * dNumB
     qAns3 = dNumA * dNumB
     qAns4 = qNumA * qNumB
     dqAns4 = qNumA * qNumB
The following instructions could be used:
      ; wAns = bNumA^2 or bNumA squared
     mov al, byte [bNumA]
     mul
                                     ; result in ax
      mov word [wAns], ax
     : wAns1 = bNumA * bNumB
     mov al, byte [bNumA]
           byte [bNumB]
                                     ; result in ax
     mul
      mov word [wAns1], ax
```



```
; dAns2 = wNumA * wNumB
     ax, word [wNumA]
mov
                                ; result in dx:ax
     word [wNumB]
mul
mov word [dAns2], ax
     word [dAns2+2], dx
mov
; qAns3 = dNumA * dNumB
     eax, dword [dNumA]
mov
     dword [dNumB]
                                ; result in edx:eax
mul
     dword [qAns3], eax
mov
     dword [qAns3+4], edx
mov
; dqAns4 = qNumA * qNumB
      rax, qword [qNumA]
mov
     qword [qNumB]
                                ; result in rdx:rax
mul
     qword [dqAns4], rax
mov
      qword [dqAns4+8], rdx
mov
```



# **Summary of mul Instruction**

| Instruction                                                                           | Explanation                                                                                                                                                                                                                                                  |  |
|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| mul <src> mul <op8> mul <op16> mul <op32> mul <op64></op64></op32></op16></op8></src> | Multiply A register (al, ax, eax, or rax) times the <src> operand.  Byte: ax = al * <src> Word: dx:ax = ax * <src> Double: edx:eax = eax * <src> Quad: rdx:rax = rax * <src> Note, <src> operand cannot be an immediate.</src></src></src></src></src></src> |  |
| Examples:                                                                             | mul word [wVvar] mul al mul dword [dVar] mul qword [qVar]                                                                                                                                                                                                    |  |



 The signed multiplication allows a wider range of operands and operand sizes. The general forms of the signed multiplication are as follows:

```
imul <source> ; <A> = <A> * <source>
imul <dest>, <src/imm> ; <dest> = <dest>*<src/imm>
imul <dest>, <src>, <imm> ; <dest> = <src> * <imm>
```

- The size of the immediate value is limited to the size of the source operand, up to a double-word size (32-bit), even for quadword multiplications.
- The final result is truncated to the size of the destination operand. A byte sized destination operand is not supported.



Ex. assuming the following data declarations:

```
wNumA dw
                  1200
     wNumB dw
                  -2000
     wAns1 dw
                  0
     wAns2 dw
     dNumA dd 42000
     dNumB dd -13000
     dAns1 dd
                  0
     dAns2 dd
     qNumA dq
                  120000
     qNumB
                  -230000
            dq
             dq
     qAns1
     qAns2
             dq
Question: To perform the basic operations of:
     wAns1 = wNumA * -13
     wAns2 = wNumA * wNumB
     dAns1 = dNumA * 113
     dAns2 = dNumA * dNumB
     qAns1 = qNumA * 7096
     qAns2 = qNumA * qNumB
```



The following instructions could be used:

```
; wAns1 = wNumA * -13
mov ax, word [wNumA]
imul ax, -13
                                        ; result in ax
mov word [wAns1], ax
; wAns2 = wNumA * wNumB
mov ax, word [wNumA]
imul ax, word [wNumB]
                                        ; result in ax
mov word [wAns2], ax
; dAns1 = dNumA * 113
    eax, dword [dNumA]
mov
imul eax, 113
                                        ; result in eax
mov dword [dAns1], eax
; dAns2 = dNumA * dNumB
mov eax, dword [dNumA]
imul eax, dword [dNumB]
                                        : result in eax
     dword [dAns2], eax
mov
```



```
; qAns1 = qNumA * 7096
            rax, qword [qNumA]
      mov
      imul rax, 7096
                                        ; result in rax
      mov qword [qAns1], rax
      ; qAns2 = qNumA * qNumB
            rax, qword [qNumA]
      mov
      imul rax, qword [qNumB]
                                        ; result in rax
            qword [qAns2], rax
      mov
Another way to perform the multiplication of
      qAns1 = qNumA * 7096
Would be as follows:
      ; qAns1 = qNumA * 7096
      mov rcx, qword [qNumA]
      imul rbx, rcx, 7096
                                        ; result in rbx
            qword [qAns1], rbx
      mov
```



## **Summary of imul Instruction**

| Instruction                                                                                                                                                                                                                                                                                    | Explanation                                                                                                                                                                                                                           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>imul <src> imul <dest>, <src imm32=""> imul <dest>, <src>, <imm32>  imul <op8> imul <op16> imul <op32> imul <op64> imul <reg16>, <op16 imm=""></op16></reg16></op64></op32></op16></op8></imm32></src></dest></src></dest></src></pre>                                                    | Signed multiply instruction.  For single operand:  Byte: ax = al * <src> Word: dx:ax = ax * <src> Double: edx:eax = eax * <src> Quad: rdx:rax = rax * <src> Note, <src> operand cannot be an immediate.</src></src></src></src></src> |
| <pre>imul <reg16>, <op16 imm=""> imul <reg32>, <op32 imm=""> imul <reg64>, <op64 imm=""> imul <reg16>, <op16>, <imm> imul <reg32>, <op32>, <imm> imul <reg64>, <op64>, <imm></imm></op64></reg64></imm></op32></reg32></imm></op16></reg16></op64></reg64></op32></reg32></op16></reg16></pre> | For two operands: <pre></pre>                                                                                                                                                                                                         |
| Examples:                                                                                                                                                                                                                                                                                      | <pre>imul ax, 17 imul al imul ebx, dword [dVar] imul rbx, dword [dVar], 791 imul rcx, qword [qVar] imul qword [qVar]</pre>                                                                                                            |



# **Integer Arithmetic Instructions**

Division



 Mathematically, there are special rules for handling division of signed values. As such, different instructions are used for unsigned division (div) and signed division (idiv).

Recall that 
$$\frac{dividend}{divisor} = quotient$$



- The A, and possibly the D register, must be used in combination for the dividend.
  - Byte Divide: ax for 16-bits
  - Word Divide: dx:ax for 32-bits
  - Double-word divide: edx:eax for 64-bits
  - Quadword Divide: rdx:rax for 128-bits
- The divisor can be a memory location or register, but not an immediate. Additionally, the result will be placed in the A register (al/ax/eax/rax) and the remainder in either the ah, dx, edx, or rdx register.
- division by zero will crash the program and damage the space-time continuum. So, try not to divide by zero.







| Quadwords |    |     |     |   |
|-----------|----|-----|-----|---|
| rdx       |    |     | rax |   |
|           | ор | 64  |     | _ |
| =         |    | rax |     |   |
| rem       |    | rdx |     |   |

Illustration 16: Integer Division Overview



 The general forms of the unsigned and signed division are as follows:

```
div <src>; unsigned division
```

idiv <src>; signed division

 The source operand and destination operands (A and D registers) are described in the preceding table.



Ex. Assuming the following data declarations:

```
bNumA
        db
            63
bNumB
        db
            17
            5
bNumC
        db
        db
            0
bAns1
bAns2
        db 0
bRem2
        db
            0
bAns3
wNumA
            4321
        dw
wNumB
            1234
        dw
            167
wNumC
        dw
wAns1
        dw
wAns2
        dw 0
wRem2
            0
        dw
wAns3
        dw
dNumA
            42000
        dd
dNumB
        dd
            -3157
dNumC
        dd
            -293
dAns1
        dd
            0
dAns2
        dd
dRem2
        dd
            0
dAns3
        dd
            730000
qNumA
            -13456
qNumB
qNumC
        dq
            -1279
qAns1
        da
            0
qAns2
        dq
            0
qRem2
        dq
qAns3
```



Question: To perform, the basic operations of:

```
bAns1 = bNumA / 3
                                    ; unsigned
bAns2 = bNumA / bNumB
                                    ; unsigned
bRem2 = bNumA % bNumB
                                    ; % is modulus
bAns3 = (bNumA * bNumC) / bNumB
                                    ; unsigned
wAns1 = wNumA / 5
                                    ; unsigned
wAns2 = wNumA / wNumB
                                    ; unsigned
wRem2 = wNumA % wNumB
                                    ; % is modulus
wAns3 = (wNumA * wNumC) / wNumB
                                    ; unsigned
dAns = dNumA / 7
                                    ; signed
dAns3 = dNumA * dNumB
                                    ; signed
dRem1 = dNumA % dNumB
                                    ; % is modulus
dAns3 = (dNumA * dNumC) / dNumB
                                    ; signed
qAns = qNumA / 9
                                    ; signed
qAns4 = qNumA * qNumB
                                    ; signed
qRem1 = qNumA % qNumB
                                    ; % is modulus
qAns3 = (qNumA * qNumC) / qNumB
                                    ; signed
```



The following instructions could be used:

```
; example byte operations, unsigned
; bAns1 = bNumA / 3 (unsigned)
      al, byte [bNumA]
mov
      ah, 0
mov
      bl, 3
mov
                                      : al = ax / 3
div
      bl
      byte [bAns1], al
mov
; bAns2 = bNumA / bNumB (unsigned)
      ax, 0
mov
      al, byte [bNumA]
mov
div
      byte [bNumB]
                                     ; al = ax / bNumB
      byte [bAns2], al
mov
       byte [bRem2], ah
                                      ; ah = ax \% bNumB
mov
; bAns3 = (bNumA * bNumC) / bNumB (unsigned)
      al, byte [bNumA]
mov
      byte [bNumC]
mul
                                      ; result in ax
      byte [bNumB]
                                      ; al = ax / bNumB
div
       byte [bAns3], al
mov
```



```
; example word operations, unsigned
; wAns1 = wNumA / 5 (unsigned)
mov ax, word [wNumA]
mov dx, 0
mov bx, 5
div bx; ax = dx:ax / 5
mov word [wAns1], ax
; wAns2 = wNumA / wNumB (unsigned)
mov dx, 0
mov ax, word [wNumA]
div word [wNumB]
                                ; ax = dx:ax / wNumB
mov word [wAns2], ax
mov word [wRem2], dx
; wAns3 = (wNumA * wNumC) / wNumB (unsigned)
mov ax, word [wNumA]
mul word [wNumC]
                                ; result in dx:ax
div word [wNumB]
                                ; ax = dx:ax / wNumB
     word [wAns3], ax
mov
```



```
; example double-word operations, signed
; dAns1 = dNumA / 7 (signed)
mov eax, dword [dNumA]
cdq
                                  ; eax \rightarrow edx:eax
mov ebx, 7
idiv ebx
                                  ; eax = edx:eax / 7
mov dword [dAns1], eax
; dAns2 = dNumA / dNumB (signed)
mov eax, dword [dNumA]
cdq; eax \rightarrow edx:eax
idiv dword [dNumB]
                                  ; eax = edx:eax/dNumB
mov dword [dAns2], eax
mov dword [dRem2], edx
                                  ; edx = edx:eax%dNumB
; dAns3 = (dNumA * dNumC) / dNumB (signed)
mov eax, dword [dNumA]
imul dword [dNumC]
                                  ; result in edx:eax
idiv dword [dNumB]
                                  ; eax = edx:eax/dNumB
      dword [dAns3], eax
mov
```



```
; example quadword operations, signed
; qAns1 = qNumA / 9 (signed)
        rax, qword [qNumA]
mov
                                          ; rax \rightarrow rdx:rax
cqo
        rbx, 9
mov
idiv
                                          ; eax = edx:eax / 9
        rbx
        qword [qAns1], rax
mov
; qAns2 = qNumA / qNumB (signed)
        rax, qword [qNumA]
mov
                                          ; rax \rightarrow rdx:rax
cqo
                                          ; rax = rdx:rax/qNumB
idiv
        qword [qNumB]
        qword [qAns2], rax
mov
        qword [qRem2], rdx
                                          ; rdx = rdx:rax%qNumB
mov
; qAns3 = (qNumA * qNumC) / qNumB (signed)
        rax, qword [qNumA]
mov
        qword [qNumC]
imul
                                          ; result in rdx:rax
        qword [qNumB]
idiv
                                          ; rax = rdx:rax/qNumB
        qword [qAns3], rax
mov
```



# **Summary of div Instruction**

| Instruction                                                                           | Explanation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|---------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| div <src> div <op8> div <op16> div <op32> div <op64></op64></op32></op16></op8></src> | Unsigned divide <b>A/D</b> register ( <b>ax</b> , <b>dx:ax</b> , <b>edx:eax</b> , or <b>rdx:rax</b> ) by the <b><src></src></b> operand.  Byte: <b>al</b> = <b>ax</b> / <b><src></src></b> , rem in <b>ah</b> Word: <b>ax</b> = <b>dx:ax</b> / <b><src></src></b> , rem in <b>dx</b> Double: <b>eax</b> = <b>eax</b> / <b><src></src></b> , rem in <b>edx</b> Quad: <b>rax</b> = <b>rax</b> / <b><src></src></b> , rem in <b>rdx</b> Note, <b><src></src></b> operand cannot be an immediate. |  |
| Examples:                                                                             | div word [wVvar] div bl div dword [dVar] div qword [qVar]                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |



# **Summary of idiv Instruction**

| Instruction                                                                                           | Explanation                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|-------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <pre>idiv <src> idiv <op8> idiv <op16> idiv <op32> idiv <op64></op64></op32></op16></op8></src></pre> | Signed divide <b>A/D</b> register ( <b>ax</b> , <b>dx</b> : <b>ax</b> , <b>edx:eax</b> , or <b>rdx:rax</b> ) by the < <b>src</b> > operand.  Byte: <b>al</b> = <b>ax</b> / < <b>src</b> >, rem in <b>ah</b> Word: <b>ax</b> = <b>dx:ax</b> / < <b>src</b> >, rem in <b>dx</b> Double: <b>eax</b> = <b>eax</b> / < <b>src</b> >, rem in <b>edx</b> Quad: <b>rax</b> = <b>rax</b> / < <b>src</b> >, rem in <b>rdx</b> Note, < <b>src</b> > operand cannot be an immediate. |  |
| Examples:                                                                                             | idiv word [wVvar] idiv bl idiv dword [dVar] idiv qword [qVar]                                                                                                                                                                                                                                                                                                                                                                                                            |  |



# **Logical Instructions**

**Logical Operations** 



### **Logical Operations**

 As you should recall, below are the truth tables for the basic logical operations;





### **Summary of Logical Instructions (1)**

| Instruction                    | Explanation                                                                                                                                                                                                                                                       |  |
|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| and <dest>, <src></src></dest> | Perform logical AND operation on two operands, ( <b>dest</b> > and <b>src</b> >) and place the result in <b>dest</b> > (over-writing previous value). <i>Note 1</i> , both operands cannot be memory. <i>Note 2</i> , destination operand cannot be an immediate. |  |
| Examples:                      | and ax, bx and rcx, rdx and eax, dword [dNum] and qword [qNum], rdx                                                                                                                                                                                               |  |
| or <dest>, <src></src></dest>  | Perform logical OR operation on two operands, ( <b>dest</b> >    <b>src</b> >) and place the result in <b>dest</b> > (over-writing previous value).  Note 1, both operands cannot be memory.  Note 2, destination operand cannot be an immediate.                 |  |
| Examples:                      | or ax, bx or rcx, rdx or eax, dword [dNum] or qword [qNum], rdx                                                                                                                                                                                                   |  |

Chap 07



### **Summary of Logical Instructions (2)**

| Instruc | tion                       | Explanation                                                                                                                                                                                                                                    |  |
|---------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| xor     | <dest>, <src></src></dest> | Perform logical XOR operation on two operands, ( <dest> ^ <src>) and place the result in <dest> (over-writing previous value). Note 1, both operands cannot be memory. Note 2, destination operand cannot be an immediate.</dest></src></dest> |  |
|         | Examples:                  | <pre>xor ax, bx xor rcx, rdx xor eax, dword [dNum] xor qword [qNum], rdx</pre>                                                                                                                                                                 |  |
| not     | <op></op>                  | Perform a logical not operation (one's complement on the operand 1's→0's and 0's→1's).  Note, operand cannot be an immediate.                                                                                                                  |  |
|         | Examples:                  | not bx not rdx not dword [dNum] not qword [qNum]                                                                                                                                                                                               |  |



# **Logical Instructions**

**Shift Operations** 



### **Logical Shift**

 The following diagram shows how the right and left shift operations work for byte sized operands.



### **Logical Shift**

- In the examples below, 23 is divided by 2 by performing a shift right logical one bit. The resulting 11 is shown in binary.
- Next, 13 is multiplied by 4 by performing a shift left logical two bits. The resulting 52 is shown in binary.

#### Shift Right Logical Unsigned Division

#### Shift Left Logical Unsigned Multiplication

Illustration 19: Logical Shift Operations



### **Summary of Logical Shift**

| Instruc    | tion                                         | Explanation                                                                                                                                                                                                                              |  |
|------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| shl<br>shl |                                              | Perform logical shift left operation on destination operand. Zero fills from right (as needed).  The <b>imm</b> > or the value in <b>cl</b> register must be between 1 and 64. <i>Note</i> , destination operand cannot be an immediate. |  |
|            | Examples:                                    | shl ax, 8 shl rcx, 32 shl eax, cl shl qword [qNum], cl                                                                                                                                                                                   |  |
| shr<br>shr | <dest>, <imm> <dest>, cl</dest></imm></dest> | Perform logical shift right operation on destination operand. Zero fills from left (as needed).  The <b>imm</b> > or the value in <b>cl</b> register must be between 1 and 64. <i>Note</i> , destination operand cannot be an immediate. |  |
|            | Examples:                                    | shr ax, 8 shr rcx, 32 shr eax, cl shr qword [qNum], cl                                                                                                                                                                                   |  |

Chap 07



#### **Arithmetic Shift**

 The following diagrams show how the shift left and shift right arithmetic operations works for a byte sized operand.





#### **Arithmetic Shift**

- The arithmetic left shift moves bits the number of specified places to the left and zero fills the least significant bit.
- The arithmetic right shift moves bits the number of specified places to the right and treats the operand as a signed number which extends the sign (negative in this example).





### **Summary of Arithmetic Shift**

| Instruction                                                     | Explanation                                                                                                                                                                                                                               |  |
|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| <pre>sal <dest>, <imm> sal <dest>, cl</dest></imm></dest></pre> | Perform arithmetic shift left operation on destination operand. Zero fills from right (as needed).  The <b>imm</b> or the value in <b>cl</b> register must be between 1 and 64. <i>Note</i> , destination operand cannot be an immediate. |  |
| Examples:                                                       | sal ax, 8 sal rcx, 32 sal eax, cl sal qword [qNum], cl                                                                                                                                                                                    |  |
| <pre>sar <dest>, <imm> sar <dest>, cl</dest></imm></dest></pre> | Perform arithmetic shift right operation on destination operand. Sign fills from left (as needed).  The <b>imm</b> or the value in <b>cl</b> register must be between 1 and 64. <i>Note</i> , destination operand cannot be an immediate. |  |
| Examples:                                                       | sar ax, 8 sar rcx, 32 sar eax, cl sar qword [qNum], cl                                                                                                                                                                                    |  |

Chap 07



#### **Rotate Operations**

 The rotate operation shifts bits within an operand, either left or right, with the bit that is shifted outside the operand is rotated around and placed at the other end.







### **Summary of Rotate Operations**

| Instruction                                          | Explanation                                                                                                                                                                                           |
|------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rol <dest>, <imm> rol <dest>, cl</dest></imm></dest> | Perform rotate left operation on destination operand.  The <b>imm</b> > or the value in <b>cl</b> register must be between 1 and 64.  Note, destination operand cannot be an immediate.               |
| Examples:                                            | rol ax, 8 rol rcx, 32 rol eax, cl rol qword [qNum], cl                                                                                                                                                |
| ror <dest>, <imm> ror <dest>, cl</dest></imm></dest> | Perform rotate right operation on destination operand.  The <b><imm></imm></b> or the value in <b>cl</b> register must be between 1 and 64. <i>Note</i> , destination operand cannot be an immediate. |
| Examples:                                            | ror ax, 8 ror rcx, 32 ror eax, cl ror qword [qNum], cl                                                                                                                                                |

Chap 07



### **Control Instructions**



#### **Control Instructions**

- Program control refers to basic programming structures such as IF statements and looping.
- Assembly language provides an unconditional branch (or jump) and a conditional branch or an IF statement that will jump to a target label or not jump.



#### **Labels**

- A program label is the target, or a location to jump to, for control statements.
- Generally, a label starts with a letter, followed by letters, numbers, or symbols (limited to "\_"), terminated with a colon (":").
- Labels in yasm are case sensitive.
- For example,

loopStart:

last:



 The unconditional instruction provides an unconditional jump to a specific location in the program denoted with a program label. The target label must be defined exactly once and accessible and within scope from the originating jump instruction.

| Instruc | tion            |           | Explanation                                                         |  |
|---------|-----------------|-----------|---------------------------------------------------------------------|--|
| jmp     | <label></label> |           | Jump to specified label.  Note, label must be defined exactly once. |  |
|         |                 | Examples: | <pre>jmp startLoop jmp ifDone jmp last</pre>                        |  |



- The conditional jump instruction will act (jump or not jump) based on the contents of the rFlag register.
- The general form of the compare instruction is:
   cmp <op1>, <op2>
- Where <op1> and <op2> are not changed and must be of the same size.
- Either, but not both, may be a memory operand.
- The <op1> operand cannot be an immediate, but the <op2> operand may be an immediate value.



 The general form of the signed conditional instructions along with an explanatory comment are as follows:

```
je
     <label>
                       ; if <op1> == <op2>
     <label>
                       ; if <op1> != <op2>
jne
     <label>
                       ; signed, if <op1> < <op2>
ile
     <label>
                       ; signed, if <op1> <= <op2>
     <label>
                       ; signed, if <op1> > <op2>
jg
     <label>
                       ; signed; if <op1> >= <op2>
jge
jb
     <label>
                       ; unsigned, if <op1> < <op2>
     <label>
jbe
                       ; unsigned, if <op1> <= <op2>
                       ; unsigned, if <op1> > <op2>
     <label>
ja
                       ; unsigned, if <op1> >= <op2>
     <label>
jae
```



Ex1. given the following pseudo-code for signed data:
 if (currNum > myMax)
 myMax = currNum;

Assuming the following data declarations:

```
currNum dq 0
myMax dq 0
```

The following instructions could be used:

```
mov rax, qword [currNum]
  cmp rax, qword [myMax] ; if currNum <= myMax
  jle notNewMax ; skip set new max
  mov qword [myMax], rax
notNewMax:</pre>
```



Ex2. A more complex example might be as follows:

```
if (x != 0) {
          ans = x / y;
          errFlg = FALSE;
} else {
          ans = 0;
          errFlg = TRUE;
}
```

Assuming the following data declarations:

| TRUE         | equ | 1            |
|--------------|-----|--------------|
| <b>FALSE</b> | equ | 0            |
| X            | dd  | 0            |
| У            | dd  | 0            |
| ans          | dd  | 0            |
| errFlg       | db  | <b>FALSE</b> |



 The following code could be used to implement the above IF-ELSE statement.

```
dword [x], 0
                                  ; if statement
   cmp
        doElse
  je
   mov eax, dword [x]
  cdq
                                  ; convert eax to rax
   idiv
        dword [y]
         dword [ans], eax
   mov
         byte [errFlg], FALSE
   mov
  jmp
         skpElse
doElse:
                                  ; else
         dword [ans], 0
                                  ; {
   mov
         byte [errFlg], TRUE
   mov
skpElse:
                                  ; }
```



### **Jump Out of Range**

- The target label must be within ±128 bytes from the conditional jump instruction.
- While this limit is not typically a problem, for very large loops, the assembler may generate an error referring to "jump out-of-range".
- The unconditional jump (jmp) is not limited in range.



### **Jump Out of Range**

 If a "jump out-of-range" is generated, it can be eliminated by reversing the logic and using an unconditional jump for the long jump. For example, the following code:

```
cmp rcx, 0 jne startOfLoop
```

 might generate a "jump out-of-range" assembler error if the label, startOfLoop, is a long distance away. The error can be eliminated with the following code:

```
cmp rcx, 0
je endOfLoop
jmp startOfLoop
endOfLoop:
```



### **Summary of Jump Instructions (1)**

| Instruction                  | Explanation                                                                                                                                                                                                   | Examples                                    |
|------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------|
| cmp <op1>, <op2></op2></op1> | Compare <op1> with <op2>. Results are stored in the rFlag register. Note 1, operands are not changed. Note 2, both operands cannot be memory. Note 3, <op1> operand cannot be an immediate.</op1></op2></op1> | cmp rax, 5 cmp ecx, edx cmp ax, word [wNum] |
| je <label></label>           | Based on preceding comparison instruction, jump to <b><label></label></b> if <b><op1></op1></b> == <b><op2></op2></b> . Label must be defined exactly once.                                                   | cmp rax, 5<br>je wasEqual                   |
| jne <label></label>          | Based on preceding comparison instruction, jump to <b><label></label></b> if <b><op1></op1></b> != <b><op2></op2></b> . Label must be defined exactly once.                                                   | cmp rax, 5<br>jne wasNotEqual               |
| jl <label></label>           | For signed data, based on preceding comparison instruction, jump to <label> if <op1> &lt; <op2>. Label must be defined exactly once.</op2></op1></label>                                                      | cmp rax, 5<br>jl wasLess                    |



### **Summary of Jump Instructions (2)**

| Instruction         | Explanation                                                                                                                                                                  | Examples                         |
|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| jle <label></label> | For signed data, based on preceding comparison instruction, jump to <b><label></label></b> if <b><op1></op1></b> <= <b><op2></op2></b> . Label must be defined exactly once. | cmp rax, 5<br>jle wasLessOrEqual |
| jg <label></label>  | For signed data, based on preceding comparison instruction, jump to <b><label></label></b> if <b><op1>&gt;<op2></op2></op1></b> . Label must be defined exactly once.        | cmp rax, 5<br>jg wasGreater      |
| jge <label></label> | For signed data, based on preceding comparison instruction, jump to <b><label></label></b> if <b><op1></op1></b> >= <b><op2></op2></b> . Label must be defined exactly once. | cmp rax, 5 Jge wasGreaterOrEqual |
| jb <label></label>  | For unsigned data, based on preceding comparison instruction, jump to <label> if <op1> &lt; <op2>. Label must be defined exactly once.</op2></op1></label>                   | cmp rax, 5<br>jl wasLess         |



### **Summary of Jump Instructions (3)**

| Instruction         | Explanation                                                                                                                                                             | Examples                         |
|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| jbe <label></label> | For unsigned data, based on preceding comparison instruction, jump to <label> if <op1> &lt;= <op2>. Label must be defined exactly once.</op2></op1></label>             | cmp rax, 5<br>jbe wasLessOrEqual |
| ja <label></label>  | For unsigned data, based on preceding comparison instruction, jump to <b><label></label></b> if <b><op1>&gt;<op2></op2></op1></b> . Label must be defined exactly once. | cmp rax, 5<br>ja wasGreater      |
| jae <label></label> | For unsigned data, based on preceding comparison instruction, jump to <label> if <op1> &gt;= <op2>. Label must be defined exactly once.</op2></op1></label>             | cmp rax, 5 jae wasGreaterOrEqual |



#### **Iteration**

 A basic loop can be implemented consisting of a counter which is checked at either the bottom or top of a loop with a compare and conditional jump.



#### **Iteration**

```
Ex1. Assuming the following declarations:
    lpCnt dq
                  15
    sum dq
The following code would sum the odd integers from 1
to 30:
    mov rcx, qword [lpCnt]; loop counter
                              ; odd integer counter
          rax, 1
    mov
  sumLoop:
    add
          qword [sum], rax; sum current odd integer
    add
                              ; set next odd integer
          rax, 2
                           ; decrement loop counter
    dec rcx
    cmp rcx, 0
          sumLoop
    jne
```



#### **General Format of Iteration**

The general format is as follows:

loop <label>

The following sets of code are equivalent:

| Code Set 1           |  | Code S | Code Set 2      |  |  |
|----------------------|--|--------|-----------------|--|--|
| loop <label></label> |  | dec    | rcx             |  |  |
|                      |  | cmp    | rcx, 0          |  |  |
|                      |  | jne    | <label></label> |  |  |



#### **General Format of Iteration**

• Ex2. The previous program can be written as follows:

```
mov rcx, qword [maxN] ; loop counter
mov rax, 1 ; odd integer counter
sumLoop:
add qword [sum], rax ; sum current odd integer
add rax, 2 ; set next odd integer
loop sumLoop
```



## **Summary of loop Instruction**

| Instruction |                 | Explanation |                                                                                                                                          |                                |
|-------------|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| loop        | <label></label> |             | Decrement <b>rcx</b> register and jump to <b><label></label></b> if <b>rcx</b> is ≠ 0. <i>Note</i> , label must be defined exactly once. |                                |
|             |                 | Examples:   | loop<br>loop<br>loop                                                                                                                     | startLoop<br>ifDone<br>sumLoop |



### **Example Program, Sum of Squares**



### Example: $1^2 + 2^2 + \cdots + 10^2 = 385$

```
; Simple example program to compute the
; sum of squares from 1 to n.
; Data declarations
section .data
; Define constants
SUCCESS
                                           ; Successful operation
                 equ
                                           ; call code for terminate
SYS exit
                          60
                 equ
; Define Data.
                 bb
                          10
n
sumOfSquares
                 da
```



### Example: $1^2 + 2^2 + \cdots + 10^2 = 385$

```
****************
section .text
global start
start:
; Compute sum of squares from 1 to n (inclusive).
; Approach:
; for (i=1; i<=n; i++)
; sumOfSquares += i^2;
      mov rbx, 1
                                        ; i
      mov ecx, dword [n]
sumLoop:
           rax, rbx
                                        ; get i
      mov
      mul
                                        ; i^2
            rax
            qword [sumOfSquares], rax
      add
            rbx
      inc
      loop
            sumLoop
```



## Example: $1^2 + 2^2 + \cdots + 10^2 = 385$

```
; -----
; Done, terminate program.

last:

mov rax, SYS_exit ; call code for exit mov rdi, SUCCESS ; exit with success syscall
```



# **End of Chapter 7**